

# DIGITAL DESIGN AND COMPUTER ORGANIZATION

Dr. Reetinder Sidhu

Department of Computer Science and Engineering



#### DIGITAL DESIGN AND COMPUTER ORGANIZATION

## **Addressing Modes**

Dr. Reetinder Sidhu

Department of Computer Science and Engineering



- Introduction
- Assembly Language
- Machine Language
- Programming
- Addressing Modes
- Lights, Camera, Action: Compiling,
   Assembling, & Loading
- Odds and Ends



## Addressing Modes Addressing Modes



## How do we address the operands?

- Register Only
- Immediate
- Base Addressing
- PC-Relative
- Pseudo Direct

## Addressing Modes (Register Only)

## **Register Only**

- Operands found in registers
  - Example: add \$s0, \$t2, \$t3
  - Example: sub \$t8, \$s1, \$0



# Addressing Modes Addressing Modes (Immediate)



#### **Immediate**

- 16-bit immediate used as an operand
  - Example: addi \$s4, \$t5, -73
  - Example: ori \$t3, \$t7, 0xFF

## Addressing Modes Addressing Modes (Base)



#### **Base Addressing**

Address of operand is:
 base address + sign-extended immediate

```
Example: lw $$4, 72($0)address = $0 + 72
```

```
Example: SW $t2, -25($t1)address = $t1 - 25
```

## Addressing Modes (PC Relative)

### **PC-Relative Addressing**



#### **Assembly Code**

#### Field Values

imm

|            |      |      | OP     |        | 1 C    |        |        |        |
|------------|------|------|--------|--------|--------|--------|--------|--------|
| beq \$t0,  | \$O, | else | 4      | 8      | О      |        | 3      |        |
| (beq \$t0, | \$O, | 3)   | 6 bits | 5 bits | 5 bits | 5 bits | 5 bits | 6 bits |

rs

On

### Addressing Modes (Pseudo-direct)

## PES UNIVERSITY ONLINE

### **Pseudo-direct Addressing**

**0x0040005C** j sum

- - -

**0x004000A0** sum: add \$v0, \$a0, \$a1

JTA 0000 0000 0100 0000 0000 0000 1010 0000 (0x004000A0)

26-bit addr 0000 0000 0100 0000 0000 0000 1010 0000 (0x0100028)

0 1 0 0 0 2 8

#### Field Values

| ор     | ımm     |           | _ |
|--------|---------|-----------|---|
| 3      |         | 0x0100028 |   |
| 6 bits | 26 bits |           | _ |

#### **Machine Code**

